草庐IT

git 撤回 (git版本回退处理)

全部标签

ruby-on-rails - 使用 Ruby on Rails 处理回形针文件夹和文件权限

我在运行Ubuntu10.04LTS的远程VPS机器上以生产模式运行RubyonRails3.0.9(在开发模式下,我在MACOSSnow上使用RoRLeopard),我想知道如何管理以下场景。我使用Apache2和PhusionPassenger并且我将虚拟主机设置为如下所示:ServerNameproject_name.comDocumentRoot/srv/www/project_name.com/publicAllowOverrideallOptions-MultiViews此外,我使用Paperclipgem,由于网上很多人在生产模式下使用它,我在处理(图像)文件时遇到以下错

ruby-on-rails - Gem::InstallError: celluloid 需要 Ruby 版本 >= 1.9.2

我正在尝试安装GitLabCI,但出现此错误。Gem::InstallError:celluloidrequiresRubyversion>=1.9.2.Anerroroccurredwhileinstallingcelluloid(0.12.4),andBundlercannotcontinue.Makesurethat`geminstallcelluloid-v'0.12.4'`succeedsbeforebundling.但是,我认为我的ruby是最新的。#ruby--versionruby1.9.3p286(2012-10-12revision37165)[i686-linux

ruby-on-rails - 如何正确处理 Rails 中的 ActiveRecord::RecordNotUnique

我试图在我的Rails项目中使用唯一索引来强制执行唯一性。我发现了一些令人困惑的事情。就像在我的站点注册用户一样,您需要提供电子邮件地址和昵称,两者都必须是唯一的。我为电子邮件和昵称添加了唯一索引。当重复出现时,我拯救异常ActiveRecord::RecordNotUnique,现在问题来了,我怎么知道哪个字段导致异常?非常感谢您的帮助。 最佳答案 恕我直言,您还应该添加uniquenessvalidators到你的模型。这允许您使用Rails的验证和错误消息。#addtomodelvalidates:email,uniquene

Ruby 并发/异步处理(简单用例)

我一直在研究ruby​​的并行/异步处理能力,并阅读了许多文章和博客文章。我查看了EventMachine、Fibers、Revactor、Reia等。不幸的是,我无法为这个非常简单的用例找到简单、有效(且非IO阻塞)的解决方案:File.open('somelogfile.txt')do|file|whileline=file.gets#(R)ReadfromIOline=process_line(line)#(P)Processthelinewrite_to_db(line)#(W)WritetheoutputtosomeIO(DBorfile)endend你看到了吗,我的小脚本正

ruby - 执行过期异常使 Ruby 线程崩溃,但处理了 Timeout::Error

任何人都可以解释为什么当对方法的调用看起来像这样时我可能会看到这个堆栈(由HTTParty::post请求引起):beginresponse=HTTParty::post(url,options)rescuelogger.warn("Couldnotpostto#{url}")rescueTimeout::Errorlogger.warn("Couldnotpostto#{url}:timeout")end堆栈:/usr/local/lib/ruby/1.8/timeout.rb:64:in`timeout'/usr/local/lib/ruby/1.8/net/protocol.rb

ruby-on-rails - 在 ruby​​ 进程之间处理大数据对象

如果使用Marshal.dump写入文件,我有一个Ruby散列达到大约10兆字节。gzip压缩后约为500KB。在ruby​​中迭代和改变这个散列是非常快的(几分之一毫秒)。即使复制它也非常快。问题是我需要在RubyonRails进程之间共享此散列中的数据。为了使用Rails缓存(file_store或memcached)执行此操作,我需要先Marshal.dump文件,但这会在序列化文件时产生1000毫秒的延迟,在序列化文件时产生400毫秒的延迟。理想情况下,我希望能够在100毫秒内从每个进程保存和加载此哈希。一个想法是生成一个新的Ruby进程来保存这个散列,该散列为其他进程提供AP

ruby-on-rails - Web 应用程序中的 API 版本控制

我目前正在为一个新网站设计版本化的API。我了解如何为路由命名空间,但我一直坚持在模型中实现版本化方法的最佳方式。下面的代码示例使用的是rails框架,但是事情的原理在大多数web框架之间应该是一致的。目前的路线看起来像这样:MyApp::Application.routes.drawdonamespace:apidonamespace:v1doresources:products,:only=>[:index,:show]endendend和Controller:classApi::V1::ProductsController很明显,我们只是在此处公开Product上可用的属性,如果

ruby - 潘戈+开罗;是否有处理文本中 <img> 样式标签的现有方法?

Pango语法支持一些纯文本标记。据我所知,这也没有扩展到嵌入图像。环顾四周,我找不到太多现有实现方式,但我之前没有做过pango+cairo工作,所以我可能会错过明显的社区。据我所知,一个合理的方法是只分析一个字符串,提取任何标签,创建cairo图像,然后相应地修改它们周围的pango布局。这看起来也像是以前有人做过的事情。我专门寻找这些问题的答案:pango+cairo是否已经解决了这个问题,我只是误读了文档?以前有没有做过这样的事情,引用在哪里?这是一种合理的方法,还是我应该尝试其他方法,什么?(还要注意我使用的是ruby​​,所以这可能会影响我的选择)

ruby - 如何在 OSX 上正确更新系统 ruby​​ 版本到最新版本 (2.2.1)

只是想更新到最新版本的Ruby。在ruby​​-lang.org/en/documentation/installation/#homebrew上,我发现你应该可以通过自制软件来完成:brewinstallruby但是,当我在“更新”后列出ruby​​版本(ruby-v)时,它仍然是旧版本2.0.0。Hermes:~Sancho$ruby-vruby2.0.0p481(2014-05-08revision45883)[universal.x86_64-darwin13]我碰巧列出了/usr/local/bin/的内容,我可以看到一个符号链接(symboliclink):ruby->..

ruby-on-rails - 如何在生产服务器中升级 rvm 和 ruby​​ 版本

我有一个带有nginx和ruby1.9.3p125(2012-02-16修订版34643)的生产服务器。我看过http://www.ruby-lang.org/en/news/2012/11/09/ruby-1-9-3-p327-is-released/我想升级到ruby-1-9-3-p327以修复安全漏洞。我在哪里可以找到升级ruby​​版本和我的rvm版本的手册或教程?谢谢 最佳答案 首先升级RVM:rvmgetstable然后升级安装的Ruby:rvmupgraderuby-1.9.3-p125ruby-1.9.3-p327h